package modelo.bd.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import modelo.bd.ConexionPool;
import modelo.bd.excepcion.DAOException;
import modelo.dominio.Area;
import modelo.servicio.Plantas;

public class AreaDAO { //extends AbstractDAO<Area> {

    private String query;

    protected synchronized List<Area> select() throws DAOException {
        Connection conexion = null;
        PreparedStatement sentencia = null;
        ResultSet resultado = null;
        List<Area> resultados = null;
        try {
            conexion = ConexionPool.getInstancia().getConexion();
            sentencia = conexion.prepareStatement(query);
            resultado = sentencia.executeQuery();
            resultados = new ArrayList<Area>();
            while (resultado.next()) {
                Area area = new Area();
                area.setIdArea(resultado.getInt("ID_AREA"));
                area.setNombre(resultado.getString("NOMBRE"));
                area.setAbreviacion(resultado.getString("ABREVIACION"));
                area.setPlanta(Plantas.instancia().obtenerPorId(resultado.getInt("ID_PLANTA")));
                resultados.add(area);
            }
        } catch (SQLException ex) {
            throw new DAOException("1 ARDS-SQL " + ex.getMessage());
        } finally {
            try {
                if (resultado != null) {
                    resultado.close();
                }
                if (sentencia != null) {
                    sentencia.close();
                }
                if (conexion != null) {
                    conexion.close();
                }
            } catch (SQLException ex) {
                throw new DAOException("2 ARDS-SQL " + ex.getMessage());
            }
        }
        return resultados;
    }

    public List<Area> selectAll() throws DAOException {
        query = "SELECT ID_AREA\n"
                + "      ,NOMBRE\n"
                + "      ,ID_PLANTA\n"
                + "      ,ABREVIACION "
                + "FROM SSMA_AREAS_T";
        return select();
    }

    public List<Area> selectWhere(String condition) throws DAOException {
        query = "SELECT ID_AREA\n"
                + "      ,NOMBRE\n"
                + "      ,ID_PLANTA\n"
                + "      ,ABREVIACION "
                + "FROM SSMA_AREAS_T "
                + "WHERE " + condition;
        return select();
    }
}
